The sliders at a top allow you to filter the neighborhoods by existing canopy in 2010 and potential canopy predicted.
As you hover your mouse over points in the scatterplot, those points will stand out in the map. You can also use the icon in the upper-right of the map to draw a box and primarily plot those areas on the graph.
You can identify the names of the neighborhoods by clicking on the blue dots in the map or hovering over points in the graph.
Note: Neighborhoods are similar to neighborhood tabulation ares, but line up slightly differently. These are based on a dataset referred to by DPR as NYC Neighborhoods Singlepart Version 10C; this was a geography used for the 2010 canopy analysis, and I’ll be digging in more on this. Any questions, e-mail me at michael.treglia@tnc.org
---
title: "Tree Canopy by Neighborhood."
output: html_notebook
author: Mike Treglia, The Nature Conservancy
date: 11 December 2017
---

<br />
<br />



##### The sliders at a top allow you to filter the neighborhoods by existing canopy in 2010 and potential canopy predicted.

##### As you hover your mouse over points in the scatterplot, those points will stand out in the map. You can also use the icon in the upper-right of the map to draw a box and primarily plot those areas on the graph.

##### You can identify the names of the neighborhoods by clicking on the blue dots in the map or hovering over points in the graph.

*Note: Neighborhoods are similar to neighborhood tabulation ares, but line up slightly differently. These are based on a dataset referred to by DPR as NYC Neighborhoods Singlepart Version 10C; this was a  geography used for the 2010 canopy analysis, and I'll be digging in more on this. Any questions, e-mail me at michael.treglia@tnc.org*

```{r, echo=FALSE, message=FALSE, error=FALSE, warning=FALSE, results='hide'}
library(RPostgreSQL)
library(sf)
library(ggplot2)

pw <- scan("~/.pgpass2", what="")

conn = dbConnect(PostgreSQL(), dbname='nycgis', user='postgres', host='mlt_host', password=pw) #[PW not needed b/c that's stored in local config files]

# fgdb <- "../../media/sf_Treglia_Data/Dropbox/TNC/Trees/MLT_Analytics/NYC_20Urban_20Tree_20Canopy_20Assessment_20Metrics_202010.gdb"


# The input file geodatabase

# List all feature classes in a file geodatabase
# subset(ogrDrivers(), grepl("GDB", name))
# fc_list <- ogrListLayers(fgdb)
# print(fc_list)
# 
# # Read the feature class
# fc <- readOGR(dsn=fgdb,layer="NYC_Community_Districts_Version10C")
# 
# 
# neighbs <- st_read(dsn=fgdb,layer="NYC_Neighborhoods_Singlepart_Version10C")
# head(nycbs)
# fc_list
# 
# tc_neighbs <- st_read(dsn=fgdb, layer="TreeCanopy_Metrics_NYC_Neighborhoods_Singlepart_Version10C", geometry_column = NULL)
# # Determine the FC extent, projection, and attribute information
# summary(fc)


neighbdata <- st_read("~/../../media/sf_Treglia_Data/Dropbox/TNC/Trees/MLT_Analytics/neighborhoodData.geojson")
st_crs(neighbdata) <- 2263

neighbdata.red <- neighbdata[,c("NEIGH_CODE", "Alt_Name", "TreeCanopy.Metrics.NYC.Neighborhoods.Singlepart.Version10C_TC_E_P", "TreeCanopy.Metrics.NYC.Neighborhoods.Singlepart.Version10C_TC_P_P", "TreeCanopy.Metrics.NYC.Neighborhoods.Singlepart.Version10C_TC_Pi_P", "TreeCanopy.Metrics.NYC.Neighborhoods.Singlepart.Version10C_TC_Pv_P")]

names(neighbdata.red)[3:6] <- c("ExistingPctCanopy", "PotentialPctCanopy_Ttl", "PotentialPctCanopy_Imperv", "PotentialPctCanopy_Veg")
head(neighbdata.red)
neighbdata.red[][[3]] <- round(neighbdata.red[][[3]], 1)
neighbdata.red[][[4]] <- round(neighbdata.red[][[4]], 1)
neighbdata.red[][[5]] <- round(neighbdata.red[][[5]], 1)
neighbdata.red[][[6]] <- round(neighbdata.red[][[6]], 1)
```


```{r, echo=FALSE, message=FALSE, error=FALSE, warning=FALSE, results='hide'}
library(plotly)
library(leaflet)
library(crosstalk)
library(rgdal)
library(sp)
library(DT)

# p <- plot_ly(neighbdata.red, x = ~ExistingPctCanopy, y = ~PotentialPctCanopy_Ttl) %>% 
#   add_markers(alpha = 0.5,text = ~paste(Alt_Name)) %>%
# 
#               
#               #hoverinfo = 'text',
#               #text = ~paste(boroughs$boroname)) %>%
#  highlight("plotly_selected", dynamic = TRUE)
#p
```

```{r, echo=FALSE, message=FALSE, error=FALSE, warning=FALSE, results='hide'}
# map <- st_transform(neighbdata.red,crs = 4326) %>% leaflet() %>% 
#   addTiles() %>% addPolygons(color = "#444444", weight = 1, smoothFactor = 0.5,
#     opacity = 1.0, fillOpacity = 0.5,
#     fillColor = ~colorQuantile("Greens", ExistingPctCanopy)(ExistingPctCanopy), highlightOptions = highlightOptions(color = "white", weight = 2,
#       bringToFront = TRUE))

#map
```

```{r, echo=FALSE, message=FALSE, error=FALSE, warning=FALSE}
sd_neigh <- SharedData$new(neighbdata.red)

neigh_centroids <- st_transform(st_centroid(neighbdata.red),crs = 4326)

sd_neigh <- SharedData$new(neigh_centroids)

test <- bscols(widths=c(7, 6, 6), device="md",
               list(filter_slider("ExistingPctCanopy", "Existing Percent Canopy", sd_neigh,
                                  ~ExistingPctCanopy, step=10, round=1, sep=""),
                    filter_slider("PotentialPctCanopy_Ttl", "Potential Percent Canopy", sd_neigh,
                                  ~PotentialPctCanopy_Ttl, step=10, round=1)),
              leaflet(sd_neigh) %>% 
              addProviderTiles(providers$CartoDB.Positron) %>%
                  addPolygons(data=st_transform(neighbdata.red, crs=4326),color = "#444444", weight = 1, 
                            smoothFactor = 0.5,
                            opacity = 1.0, 
                            fillOpacity = 0.5,
                            fillColor = ~colorQuantile("Greens", ExistingPctCanopy)(ExistingPctCanopy), 
                            highlightOptions = highlightOptions(color = "white", weight = 2,
                                                                bringToFront = FALSE), group="Existing Percent Canopy") %>% 
                addPolygons(data=st_transform(neighbdata.red, crs=4326),color = "#444444", weight = 1, 
                            smoothFactor = 0.5,
                            opacity = 1.0, 
                            fillOpacity = 0.5,
                            fillColor = ~colorQuantile("Greens", 
                                                       PotentialPctCanopy_Ttl)(PotentialPctCanopy_Ttl), 
                            highlightOptions = highlightOptions(color = "white", weight = 2,
                                                                bringToFront = FALSE), group="Potential Percent Canopy") %>% 
              addCircleMarkers(radius=5, stroke=TRUE, color="yellow", weight=1,fillColor = "#03F",
                               opacity=1,fillOpacity=1, group="pts",
                               popup=~as.character(Alt_Name)) %>%
              addLayersControl(baseGroups = c("Existing Percent Canopy", "Potential Percent Canopy"),overlayGroups="Neighborhoods",
                              options = layersControlOptions(collapsed = FALSE)),
              plot_ly(sd_neigh, x = ~ExistingPctCanopy, y = ~PotentialPctCanopy_Ttl) %>% 
                  add_markers(alpha = 0.5,text = ~Alt_Name) %>% 
                  layout(xaxis = list(title="Existing % Canopy (2010)"), 
                         yaxis = list(title="Potential % Canopy")) %>%
                  highlight("plotly_hover", off='plotly_deselect', 
                            opacityDim=getOption("opacityDim",  0.2)))

test
```

<br /> 
<br />
